草庐IT

以太网连接HTTP POST

全部标签

mongodb - 如何将本地Mongo数据库连接到docker

我正在从事golang项目,最近我阅读了有关docker的信息,并尝试在我的应用程序中使用docker。我正在使用mongoDB作为数据库。现在的问题是,我正在创建Dockerfile来安装所有包并编译和运行go项目。我在本地运行mongo数据,如果我在没有docker的情况下运行go程序,它会给我输出,但是如果我在同一个项目中使用docker(只是安装依赖项并运行这个项目),它编译成功但没有给出任何输出,有错误::CreateSession:noreachableservers我的Dockerfile::#StartfromaDebianimagewiththelatestversi

postgresql - 微服务使 postgres 连接倍增

我有一个通过golang编写的服务,它作为消费者工作,它从kafka的队列中获取数据并将其存储在PostgreSQL数据库中。在执行某些请求时,golang开始增加PG连接,然后超过它们的限制。我不知道为什么,请帮我解决这个问题。这是代码:funcSaveMessageStatus(msgmodels.Message)error{db:=GetPostgreInstance()//Get*sql.DBinstance//Проверяеместьлизаписиrows,err:=db.Query(`select*from"tNotifStatus"where"Notification

http - 如果内容长度错误,Chrome 会关闭 tcp 连接吗?

我对Web服务器对httpkeep-aliveheader的操作很感兴趣。所以我在httpserver的基础上搭建了一个简单的httpserver。服务器除了使用简单的htmlhttp正文响应客户端之外什么都不做。服务器代码在这里:packagemainimport("fmt""net""os")funcmain(){l,err:=net.Listen("tcp","localhost:9765")iferr!=nil{fmt.Println("Errorlistening:",err.Error())os.Exit(1)}deferl.Close()for{conn,err:=l.A

unit-testing - 如何在不创建实际网络连接的情况下测试依赖于 net.Conn 的代码?

如果我有适用于net.Conn的代码,我如何在不实际创建与本地主机的网络连接的情况下为其编写测试?我在网上没有看到这个问题的解决方案;人们似乎要么忽略它(不进行测试),要么编写无法并行运行的测试(即使用实际的网络连接,这会耗尽端口),要么使用io.Pipe。不过,net.Conn定义了SetReadDeadline、SetWriteDeadline;而io.Pipe没有。net.Pipe也没有,尽管表面上声称要实现该接口(interface),但它只是通过以下方式实现:func(p*pipe)SetDeadline(ttime.Time)error{return&OpError{Op:

go - 使用go-sql-driver时如何区分连接错误和其他错误

funcmainloop(db*sql.DB){typepushTaskstruct{TaskIdstringUristring}stmt,err:=db.Prepare("INSERTINTOErrPushCache(TaskId,Uri)VALUES(?,?)")iferr!=nil{log.Fatal("db.PrepareFailed",err)}var(mysqlOkbool=truetaskpushTask)for{task.TaskId=RandStringRunes(8)task.Uri=RandStringRunes(16)res,err:=stmt.Exec(tas

database - go database/sql - 奇怪的连接和事务行为

使用Go和使用database/sql的数据库驱动程序的实现,我似乎遇到的交易行为似乎是每次交易后都需要关闭连接。如果我不这样做,数据库将耗尽连接,并且我会收到以下错误:"BeginTransactionfailed.Error=Error1040:Toomanyconnections".Thishappensafter101commits.我尝试使用来自github的两个不同驱动程序-lib/pq和go-sql-driver/mysql,结果相同。这种行为对我来说很奇怪。这是预料之中的,还是我做错了什么?根据要求,代码如下:packagemainimport("database/sq

go - 从列表中删除客户端会终止其他连接

为什么要杀死一个简单的“ClientList.Remove(entry)”所有来自其他客户端的连接?我有一个非常简单的GoTCP服务器,可以进行连接处理和登录处理。之后,如果创建一个客户端并使用TCP客户端启动一个GORoutine。newClient:=&Client{"","",login.LoginToken,conn}去ClientReader(newClient)ClientList.PushBack(*newClient)Go例程读取所有传入数据。当连接超时或网络发生变化时(客户端获得新IP)它将客户从客户列表中删除。但是当它从列表中删除客户端时......所有其他客户端连

go - 如何使用golang连接到配置单元

我使用https://github.com/apache/hive/blob/trunk/service/if/TCLIService.thrift到gengolangsdk,但它不起作用。golangsdk只能opensession。我在pythonsdk中比较了我的代码,没有发现任何错误用法。下面是我的golang代码。socket,err:=thrift.NewTSocket("localhost:11000")iferr!=nil{fmt.Printf("%s\n",err)return}trans:=thrift.NewTBufferedTransport(socket,10

sockets - 限制连接到网络服务的客户端数量

如何限制连接到我的服务的客户端数量?我尝试了一个简单的计数器,但是如果客户端没有关闭就退出了他们的联系我不知道怎么弄的。请有人给我一些想法以便得到它吗?constMAX_CLIENTS=5varConnectedClientsintfuncmain(){ConnectedClients=0server,err:=net.Listen(CONN_TYPE,net.JoinHostPort(CONN_HOST,CONN_PORT))iferr!=nil{fmt.Println("ErrorListening",err.Error())os.Exit(1)}deferserver.Close

mongodb - Golang 数据库连接池与 mongodb

这几天我在一个性能测试项目上做了一些测试场景,其中我结合了golang+mongodb,结果非常令人印象深刻,但是当你发送多个请求时,性能会急剧下降我猜这个问题是因为没有连接池(也许?),我是一名java开发人员,mongodb的mongodbjava驱动程序隐含了一个连接池。那么有连接池还是我自己创建一个?谢谢 最佳答案 目前(2020-01-29),根据未公开记录的MongoDB-GO-Driver官方标准,官方驱动本身会维护一个连接池,你只需要设置池大小(min&max).可以在以下位置找到引用:OfficialGitHubR